// pages/recommendSong/recommendSong.js
import PubSub from 'pubsub-js';

import {
  API_MusicList
} from '../../../api/api_recommendSong'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    day: '',
    month: '',
    recommendlist: [], //推荐音乐列表
    index: 0, //当前播放歌曲的index
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    // 判断是否登录
    let userInfo = wx.getStorageSync('userInfo');
    if (!userInfo) {
      wx.showToast({
        title: '请先登录',
        icon: 'error',
        success() {
          setTimeout(() => {
            wx.reLaunch({
              url: '/pages/login/login'
            })
          }, 1000);
        }
      })
    }
    // 更新时间
    this.setData({
      day: new Date().getDate(),
      month: new Date().getMonth() + 1,
    })
    // 获取推荐歌列表
    this.getMusciList();

    // 订阅来自songDetail的消息
    PubSub.subscribe('switchMusci', (msg, type) => {
      let {
        recommendlist,
        index
      } = this.data;
      if (type === 'pre') {
        (index === 0) && (index = recommendlist.length)
        index -= 1;
      } else {
        (index === recommendlist.length - 1) && (index = -1)
        index += 1;
      }

      this.setData({
        index,
      })
      let musinId = recommendlist[index].id;
      PubSub.publish('musicId', musinId)
    })

  },
  // 获取推荐歌曲列表
  async getMusciList() {
    const res = await API_MusicList();
    this.setData({
      recommendlist: res.recommend
    })
  },
  // 监听点击到播放详情页
  toDetail(event) {
    let songId = event.currentTarget.dataset.item.id;
    let index = event.currentTarget.dataset.index;
    this.setData({
      index
    })
    wx.navigateTo({
      url: '/songPackage/pages/songDetail/songDetail?songId=' + songId
    })
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})